草庐IT

HTTP 响应头信息

全部标签

ruby-on-rails - 如何在可配置的超时时间内响应 Rails 请求

我想在不使用超时模块的情况下在Controller的操作中实现以下行为:classAdminController我想避免使用超时,因为它会在我的应用程序中导致许多错误,包括数据库连接泄漏。报告的其他一些问题:http://www.mikeperham.com/2015/05/08/timeout-rubys-most-dangerous-api/ 最佳答案 不要为此使用ruby。问题是超时模块将在执行代码的任何地方中止代码,这将导致打开和悬空的套接字、连接和文件或更糟。(我想,如果你启动外部脚本或为每项工作支付费用,这并不是真正的问

ruby-on-rails - Ruby NET::HTTP 在主体之前读取 header (没有 HEAD 请求)?

我使用Net::HTTP和Ruby来抓取URL。我不想抓取流式音频,例如:http://listen2.openstream.co/334其实我只想抓取Html内容,所以没有pdfs、video、txt..现在,我将open_timeout和read_timeout都设置为10,所以即使我抓取这些流式音频页面,它们也会超时。url='http://listen2.openstream.co/334'path=uri.pathreq=Net::HTTP::Get.new(path,{'Accept'=>'*/*','Content-Type'=>'text/plain;charset=u

ruby - `open_http' : 403 Forbidden (OpenURI::HTTPError) 字符串 "Steve_Jobs"但不是任何其他字符串

我正在学习http://ruby.bastardsbook.com/提供的Ruby教程我遇到了以下代码:require"open-uri"remote_base_url="http://en.wikipedia.org/wiki"r1="Steve_Wozniak"r2="Steve_Jobs"f1="my_copy_of-"+r1+".html"f2="my_copy_of-"+r2+".html"#readthefirsturlremote_full_url=remote_base_url+"/"+r1rpage=open(remote_full_url).read#writeth

ruby-on-rails - 从 rails 中的 url 获取 Controller 和操作信息

如果有相应的路由规则,我如何获取有关任何(不仅是当前)url的Controller和操作名称的信息?例如:function_i_need('/pages/5')返回{:controller=>'page',:action=>'show',:id=>5}UPD:已找到答案Railsparseurltohash(Routes) 最佳答案 你可以这样做:Rails.application.routes.recognize_path"/pages/5" 关于ruby-on-rails-从rail

ruby - 如何在使用 Ruby 的 OpenUri 下载之前获取 HTTP header

我目前正在使用OpenURI下载Ruby中的文件。不幸的是,如果不下载完整文件,似乎不可能获得HTTPheader:open(base_url,:content_length_proc=>lambda{|t|ift&&0t)end},:progress_proc=>lambda{|s|pbar.progress=sifpbar}){|io|putsio.sizeputsio.meta['content-disposition']}运行上面的代码表明它首先下载了完整的文件,然后才打印我需要的标题。有没有办法在下载完整文件之前获取header,以便在header与我预期的不同时取消下载?

ruby - Heroku 上 Rack::Static 应用程序的 HTTP 基本身份验证

我在Heroku上托管了一个简单的Rack应用程序。配置.ru:useRack::Static,:urls=>["/stylesheets","/images","/javascripts"],:root=>"public"runlambda{|env|[200,{'Content-Type'=>'text/html','Cache-Control'=>'public,max-age=86400'},File.open('public/index.html',File::RDONLY)]}如何向其中添加HTTP基本身份验证?如果它只适用于生产环境,则加分。谢谢

ruby-on-rails - 我可以从模型中获取表、列和类型信息吗?

我正在使用ruby​​和activerecord获取有关mysql表的信息。我希望我可以直接从我的模型类中获取这些信息,这可能吗?假设我有我的模型:classProduct我现在可以获取以下信息吗:1.mysqltable2.columns3.columntypes或者我是否必须更深入地查看ActiveRecord模块才能获得它? 最佳答案 Product.table_nameProduct.column_namesProduct.columns_hash['title'].type 关

ruby - 在 ruby​​ 中访问 Net::HTTP::Post 的 header

我有以下代码:uri=URI.parse("https://rs.xxx-travel.com/wbsapi/RequestListenerServlet")https=Net::HTTP.new(uri.host,uri.port)https.use_ssl=truereq=Net::HTTP::Post.new(uri.path)req.body=searchxmlreq["Accept-Encoding"]='gzip'res=https.request(req)这通常工作正常,但另一端的服务器提示我的XML中的某些内容,那里的技术人员需要xml消息和正在发送的header。我收

ruby - 在 Sinatra 中缓存响应的最佳方式?

我正在使用我用Sinatra创建的API构建一个简单的应用程序,该API返回一些JSON。这是相当多的JSON,我的应用程序的API依赖于对其他API的数百个请求。我大概可以缓存5天左右的结果,数据完全没有问题。我只是不是100%确定如何实现缓存。我将如何使用Sinatra做到这一点? 最佳答案 就我个人而言,比起memcached,我更喜欢将redis用于此类事情。我有一个应用程序,我非常广泛地使用redis,以与您描述的类似的方式使用它。如果我进行未缓存的调用,页面加载时间会超过5秒,而使用Redis,加载时间会下降到0.3秒左

ruby - 如何将 Net::HTTP 响应转换为 Ruby 1.9.1 中的特定编码?

我有一个Sinatra应用程序(http://analyzethis.espace-technologies.com)执行以下操作检索HTML页面(通过net/http)从response.body创建一个Nokogiri文档提取一些信息并在响应中发回。响应应采用UTF-8编码所以我在尝试阅读使用windows-1256编码的网站(如www.filfan.com或www.masrawy.com)时遇到了问题。问题是编码转换的结果不正确,虽然没有抛出错误。net/httpresponse.body.encoding给出了ASCII-8BIT,无法转换为UTF-8如果我执行Nokogiri